package com.itheima.tilas.service;

import com.itheima.tilas.Utils.ResultUtil;
import com.itheima.tilas.dto.SelectEmpCountGender;
import com.itheima.tilas.dto.SelectEmpCountJob;
import com.itheima.tilas.dto.SelectEmpDetailDTO;
import com.itheima.tilas.dto.SelectEmpPageDTO;
import com.itheima.tilas.entity.Emp;
import com.itheima.tilas.po.InsertEmpOneParam;
import com.itheima.tilas.po.SelectEmpPageParam;
import com.itheima.tilas.po.UpdateEmpOneParam;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 员工表服务层
 * @author 132
 */
public interface EmpService {
    /**
     * 分页查询员工信息
     * @param pageParam 存储查询参数的变量
     * @return 返回查询到的信息
     */
    ResultUtil selectEmpPageAll(SelectEmpPageParam pageParam);

    /**
     * 根据id查询信息
     * @param id 需要查询的id
     * @return 返回查询的信息
     */
    SelectEmpDetailDTO selectEmpById(Integer id);

    /**
     * 插入一条信息
     * @param one 存储要插入的信息的变量
     * @return 返回影响数据库信息的条数
     */
    int insertEmpOne(InsertEmpOneParam one);
    /**
     * 根据id批量删除信息
     * @param ids 存储要删除的id列表
     * @return 返回影响数据库信息的条数
     */
    int deleteEmpByIds(List<Integer> ids);
    /**
     * 根据id修改员工信息
     * @param emp 存储需要修改信息的变量
     * @return 返回影响数据库信息的条数
     */
    int updateEmpOne(UpdateEmpOneParam emp);

    /**
     * 查询全部员工信息
     * @return 返回员工信息集合
     */
    List<Emp> selectEmpAll();

    /**
     * 统计学生性别人数
     * @return 返回学生性别信息
     */
    List<SelectEmpCountGender> selectEmpCountGender();

    /**
     * 统计员工工作职位人数
     * @return 返回员工职位人数信息
     */
    ResultUtil selectEmpCountJob();
}
